10

15

20

25

## IMAGE PROCESSING APPARATUS AND METHOD

This application is based on Japanese Patent Application HEI 11-089364, filed on March 30, 1999, the entire contents of which are incorporated herein by reference.

## BACKGROUND OF THE INVENTION

# a) Field of the Invention

The present invention relates to techniques of processing image data output from an image sensor, and more particularly to an image processing apparatus and method which can compensate for defects of pixels of an image sensor through digital data processing.

# b) Description of the Related Art

Fig. 5 shows the structure of a general image processing apparatus.

An image processing apparatus may be a digital camera. Image data output from an image sensor (CCD) 10 is sequentially written in a DRAM 11, for example, one line after another. Pixel data of all lines, i.e., image data of one frame, is temporarily written in DRAM 11.

The image data of one frame once written in DRAM 11 is read under the control of a host CPU 12 to write it in another storage medium, to output it to a display device, or to further process it and output the result.

An image sensor 10 manufactured in a semiconductor factory has defective pixels with some percentage. Even if there are some defective pixels among several hundred thousand pixels or several million pixels of each product, such defects are permitted as commercial products. Since pixel defects lower the image quality, it is preferable to correct the defects by some means. For example,

20

25

5

data of defective pixels are corrected by digital processing techniques or the like.

The positions of defective pixels of an image sensor can be known at the stage of manufacture inspection. The position information of defective pixels is supplied from a manufacturer of image sensors, and stored in an external memory 13. The position information of defective pixels is supplied from the external memory 13 to the host CPU 12 which executes a process of correcting data of defective pixels of the image sensor in the following manner.

Image data of one frame supplied from the image sensor 10 is once written in DRAM 11 together with image data of defective pixels. Next, the position information of defective pixels of the first one line is fetched from the external memory 13 to correct the data of the defective pixels designated by the defective pixel position information. This defective data correction process is performed for all lines containing defective pixels.

Referring to Figs. 4(A) and 4(B), a process of correcting defective pixel Fig. 4(A) is a schematic diagram showing a layout of some data will be detailed. pixels in one line of a monochrome image sensor. A pixel 21 indicated by a cross mark is a defective pixel. In accordance with the defective pixel position information, the host CPU 12 reads the data of normal pixels 20 and 22 one pixel before and after the defective pixel 21, from DRAM 11. An average of the data of the pixels 20 and 22 is calculated. The data at an address of the defective pixel 21 in DRAM 11 is replaced by the calculated average data. This data correction process is executed for all lines containing defective pixels, and the data of defective pixels in DRAM 11 is corrected.

Fig. 4B is a schematic diagram showing a layout of some pixels in two lines of a color image sensor. This pixel layout is called a Bayer matrix. Bayer matrix, a row alternately disposing an R (red) pixel and a G (green) pixel and a

20

25

5

row alternately disposing a B (blue) pixel and a G (green) pixel are alternately disposed in the column direction.

It is assumed that an R pixel 31 indicated by a cross mark is a defective pixel in a subject line n. In accordance with the defective pixel position information, the host CPU 12 reads the data of normal R pixels (same color as the defective pixel) forward and backward nearest to the defective pixel 31, from DRAM 11. An average of the data of the two normal pixels 30 and 32 is calculated. The data in DRAM 11 at an address of the defective R pixel 31 is replaced by the calculated average data. Defective data for the B and G pixels is corrected by the similar process. This data correction process is executed for all lines containing defective pixels, and the data of defective pixels in DRAM 11 is corrected.

Image data of one frame subjected to the defect data correction is read from DRAM 11 to follow a next process of reading the image data in another storage, to output it to a display device, or to further process it and output the result.

The image processing apparatus described above executes the defect pixel data correction process after image data of one frame from the image sensor is once written in DRAM 11. The operation of reading data of normal pixels near the defective pixel from DRAM 11, executing the defective pixel data correction process, and overwriting image data in DRAM 11 takes a process time of about 10 clocks.

Since the defective pixel data correction process is repeated as many as the number of defective pixels, it takes a fairly long to calculate the correction data for all defective pixels and write it in DRAM. This results in a long time taken to correct image data of one frame picked up with an image sensor with defective pixels and output corrected image data. There is therefore a long wait time for a picked up image to be displayed. Since the time necessary for the defective pixel data correction is long, this correction is not applied to a monitor moving image having a

25

5

frame rate of 30 frames per sec.

#### SUMMARY OF THE INVENTION

It is an object of the present invention to provide an image processing apparatus and method capable of correcting data of defective pixels at high speed and with a simple circuit structure.

According to one aspect of the present invention, there is provided an image processing apparatus for processing image data supplied from an image sensor, comprising: a memory having a first field for storing image data of one frame and a second field for storing position data of a defective pixel of the image sensor; control means for controlling image data to write into the memory and image data to read from the memory; a counter for counting the number of pixels of image data sequentially transferred from the image sensor, and a defect correction circuit for correcting the image data of each pixel sequentially transferred from the image sensor in accordance with image data of pixels adjacent to a pixel whose image data is currently transferred, wherein the control means writes the image data corrected by the defect correction circuit in the first field of the memory at a storage location corresponding to the defect pixel, if a count of the counter becomes coincident with a number corresponding to the position data of the defective pixel in the second field of the memory, and writes the image data supplied directly from the image sensor in the first field, if the count is not coincident with the number corresponding to the position data of the defective pixel.

According to another aspect of the invention, there is provided an image processing method of processing image data supplied from an image sensor, comprising the steps of: (a) reading defective pixel position data of one line of the image sensor from a memory; (b) sequentially fetching the image data from the image

sensor; (c) counting the number of pixels of the image data fetched from the image sensor; (d) correcting the image data sequentially transferred from the image sensor in accordance with image data of pixels adjacent to a pixel whose image data is currently transferred; and (e) writing the corrected image data in the memory at a storage location corresponding to the defective pixel, if a count becomes coincident with a number corresponding to the position data of the defective pixel, and writing the image data not corrected and supplied directly from the image sensor in the memory, if the count is not coincident with the number corresponding to the position data of the defective pixel.

Each time image data is fetched from the image sensor, the data correction process for a defective pixel is executed, and image data of a normal pixel or correction data of a defective pixel is written in the memory. Accordingly, image processing can be performed at high speed.

As above, image processing substantially in real time is possible. An image picked up with an image sensor having defective pixels can be corrected and reproduced at high speed. A moving image can also be reproduced substantially in real time. Image data of a defective pixel can be corrected with a simple circuit.

# BRIEF DESCRIPTION OF THE DRAWINGS

5

**3**0

...J '\...J

1;N 1;N

j

1.3

25

Figs. 1A, 1B and 1C are a block diagram of an image processing apparatus and diagrams illustrating the operation thereof, according to an embodiment of the invention.

Fig. 2 is a flow chart illustrating the operation of the image processing method according to an embodiment of the invention.

Figs. 3A and 3B are block diagrams showing the structure of a defect correction circuit of the image processing apparatus of the invention, Fig. 3A shows

20

25

5

the structure of the circuit performing a correction process using adjacent pixels in the row direction, and Fig. 3B shows the structure of the circuit performing a correction process using adjacent pixels in the column direction.

Figs. 4A and 4B are diagrams showing the layout of pixels illustrating how data of defective pixels is corrected.

Fig. 5 is a block diagram of a conventional image processing apparatus.

## DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

Figs. 1A, 1B and 1C are a block diagram of an image processing apparatus and diagrams illustrating the operation thereof, according to an embodiment of the invention. Fig. 2 is a flow chart illustrating the operation of the image processing method to be executed by the apparatus shown in Figs. 1A to 1C. the method including a defective pixel data correction process. With reference to the accompanying drawings, the operation of the embodiment apparatus will be Referring to Fig. 1A, reference numeral 1 represents a counter for described. counting the number of pixels of image data of one frame to be transferred from an image sensor (CCD) 10. The image data is serially transferred from the image sensor at a clock signal of, for example, 12.27 MHz. Reference numeral 2 represents a correction circuit for defective pixel data. Reference numeral 3 represents an image data delay circuit. Reference numeral 4 represents a DRAM for storing image data and defective pixel information of at least one frame. Reference numeral 5 represents a host CPU for controlling these circuits. Reference numeral 6 represents a bus line. Reference numeral 13 represents an external memory for storing the defective pixel information of the image sensor 10. The defective pixel information is supplied from a manufacturer of the image sensor.

The memory field of DRAM 4 includes an image data field 4a for storing

10

15

20

25

image data of one frame and a defective pixel field 4b for storing detective pixel information. The pixel defect information of the image sensor 10 in the external memory 13 is supplied to and stored in the defect information field 4b.

The memory field of DRAM 4 is schematically shown in Fig. 1B. An address in DRAM 4 is identified by a row address RA and a column address CA. In the image data field 4a, image data of each line of the image sensor 10 is stored in each field L1 to Ln (n is the line number) at a corresponding row address RA, and defective pixel information of each line is also stored in each field D1 to Dn at a corresponding row address. For example, pixel data of the first line is stored in the field L1 at the first row address, and the defective pixel information of the first line is stored in the field D1 at the first row address.

Fig. 1C shows the format of the defective pixel information field Dn. If a flag 51 of upper 4 bits is 0, it means that there is a single defective pixel at the n-th line. If the flag is 1, it means that there are two consecutive defective pixels. If the flag is 2, it means that there are three consecutive defective pixels. If the flag is 3, it means that there are four consecutive defective pixels. A defective pixel position information field 52 of lower 12 bits indicates the position of a single defective pixel on the line, and indicates the position of the first detective pixel if there are consecutive defective pixels.

For example, DRAM 4 can store data of 16 bits at one address, and each field Dn has four sets of the defective pixel information of 16 bits shown in Fig. 1C. These numbers are only illustrative and the embodiment is not intended to be limited to those numbers. If there is no defective pixel in line, the position information field 52 is set with 1 for all lower 12 bits.

With the memory format of this embodiment, if the image size of the image sensor corresponds to, for example, VGA (640 horizontal pixels x 480 lines),

10

15

20

25

the defective position information can show the positions of maximum 7680 defective pixels (= 4 consecutive defects x 4 sets x 480 lines), and the data of these defective pixels can be corrected.

The image processing process of this embodiment will be described with reference to Fig. 2 and when necessary to Figs. 1A to 1C. First, prior to fetching the image data of the first line from the image sensor 10, the defective pixel data of the first line is read from the defective pixel information field 4b (Fig. 1B) of DRAM 4. The read information is supplied to the counter 1 (Fig. 1A) at Step 40. For example, a number corresponding to the position of a defective pixel is input to the counter 1, and each time data of a pixel is supplied, the count is decremented so that when the count becomes 0, the supplied data is the data of the defective pixel.

Next, at Step 41 the operation of fetching image data from the image sensor 10 starts. During this data fetch, the counter 1 counts the number of pixels of the fetched data. In parallel to the image data fetch, the defect correction circuit 2 generates (calculates) correction data for all of the pixels irrespective of whether or not there is a defective pixel. The correction data generation (calculation) is performed by a method similar to that described with reference to Figs. 4A and 4B. In this embodiment, however, the correction data generation (calculation) is performed by the defect correction circuit 2, whereas the conventional apparatus shown in Fig. 5, it is performed by the host CPU 12.

Fig. 3A shows an example of the defect correction circuit 2 for monochrome image data. In order to generate the correction data for each pixel, data A and data B adjacent to the subject pixel are input to an adder 61 and added together. The lowest bit of the addition result A + B is cut off so that ((A+B)/2) or an average of A and B can be obtained. A more specific example will be described.

First, the case wherein the correction data is generated by using data of

20

25

5

adjacent pixels in the row direction will be described. It is assumed that the correction data for the m-th (m is an optional positive integer) pixel of the first line is generated. Pixel data (8 bits) X(m-1) at (m-1)-th pixel and pixel data (8 bits) X(m+1) at (m+1)-th pixel are input from the image sensor to the adder 61 to calculate a sum [X(m-1) + X(m+1)]. Of the 9-bit output from the adder 61, the upper 8 bits are selected. Namely, the sum is divided by 2, i.e., [X(m-1) + X(m+1)]/2, by cutting off the lowest one bit. The value of the upper 8 bits is an average of the input data of two pixels, and is used as the correction data. The defect correction is fundamentally the same for color image data. The correction data may be generated by another known method instead of the above-described method.

Next, it is checked at Step 42 whether the count becomes coincident with the value corresponding to the defect pixel position information in the defect pixel information field 4b. If coincident, at Step 43 the correction data generated at Step 41 is written in the data field 4a of DRAM 4 at the address of the defective pixel position. If not coincident at Step 42, the image data supplied from the image sensor 10 and delayed by a delay circuit 3 by a proper time, e.g., one row, in response to an instruction from the host CPU 5 issued in accordance with the defect position information, is written in the data field 4a of DRAM 4.

Next, it is checked at Step 47 whether the process is completed for all pixel data in the line. If not, the flow returns to Step 41 to repeat the above process for the next pixel data. If the process is completed for all pixel data in the line, the flow advances to Step 45.

It is checked at Step 45 whether data of all lines is written. If not, the flow returns to Step 40 to repeat the above process for the next line. The above process is repeated until image data of all lines of one frame is written in DRAM 4.

After all the image data including correction data is written in DRAM 4,

10

15

20

25

the image data is read from DRAM 4 at Step 46. If necessary, another image processing is executed and then the image data is supplied to the display device.

Moving image data is received from the image sensor at a clock of, for example, 12.27 MHz. Moving image data is supplied to the display device at a clock of, for example, 12.27 MHz. With the embodiment method, moving image data received from the image sensor 10 can be corrected and displayed on the display device in real time of 30 frames/sec.

If the data read time of DRAM 4 is considerably faster than the data transfer rate, data may be read and output each time the data write at Step 43 or Step 44 is completed.

If the pixel at the end of one line is a defective pixel, the correction data can be generated by using the data of the pixel adjacent to the subject pixel. If there are consecutive defective pixels in one line, the correction data can be generated through vertical interpolation. If an L row contains consecutive defective pixels, the correction data is generated by using the data of corresponding m-th pixels at (L-1) and (L+1) rows. In this case, the delay circuit gives a delay time corresponding to three rows to the image data supplied from CCD 10 in response to an instruction the host CPU 5 issued in accordance with the defect pixel information in DRAM 4. The correction data may be generated through weighted mean in accordance with distances from the defective pixel.

Fig. 3B shows an example of the defect correction circuit capable of calculating weighted mean. In generating the correction data of a defective pixel, data A and data B of adjacent pixels are input to an adder 61. In this case, for example, a distance from the defective pixel is taken into consideration. It is assumed that the distance of the pixel of data A is a<sub>1</sub> from the defective pixel, and the distance of the pixel of data B is b<sub>1</sub> from the defective pixel. The data input to the

adder 61 is weighted to, for example,  $cA/1_1$  and  $cB/b_1$ . The data is added by the adder and bit-shifted to output weighted mean of  $(cA/a_1 + cB/b_1)/2 = c(Ab_1 + Ba_1)/2a_1b_1$ .

In this embodiment, the memory is provided with the field for storing defective pixel information, each time pixel data is fetched from the image sensor, the data correction process is executed, and image data or correction data is selected in accordance with the defective pixel information and written in the memory. Image processing substantially in real time is possible for each line. An image picked up with an image sensor having defective pixels can be corrected and reproduced at high speed. A moving image can also reproduced substantially in real time. Image data of a defective pixel can be corrected with a simple circuit including the counter and defect correction circuit.

**1**0

1,7

ក្រៅ ក្រា

ij

1.3

The present invention has been described in connection with the preferred embodiments. The invention is not limited only to the above embodiments. It is apparent that various modifications, improvements, combinations, and the like can be made by those skilled in the art.